@import './base.css';

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  background: linear-gradient(135deg, #e0f2e9 0%, #d4e7f1 100%);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  position: relative;
}

/* 添加动态背景效果 */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    radial-gradient(circle at 15% 50%, rgba(149, 212, 117, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 85% 30%, rgba(149, 212, 117, 0.1) 0%, transparent 50%),
    linear-gradient(135deg, #e0f2e9 0%, #d4e7f1 100%);
  animation: gradientMove 15s ease infinite;
  z-index: -1;
}

@keyframes gradientMove {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

#app {
  width: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 0;
}

/* 全局过渡效果 */
.fade-enter-active,
.fade-leave-active {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
  transform: translateY(10px);
}

/* 添加移动端适配基础样式 */
:root {
  --safe-area-inset-bottom: env(safe-area-inset-bottom);
  --mobile-header-height: 56px;
  --mobile-footer-height: 50px;
}

html {
  font-size: 16px;
  /* 移动端字体优化 */
  -webkit-text-size-adjust: 100%;
}

body {
  /* 禁用页面弹性滚动 */
  overscroll-behavior: none;
  /* 优化移动端触摸体验 */
  -webkit-tap-highlight-color: transparent;
}

/* 移动端容器基础样式 */
.mobile-container {
  padding: 1rem;
  max-width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

/* 响应式布局调整 */
@media screen and (max-width: 768px) {
  html {
    font-size: 14px;
  }
  
  .mobile-container {
    padding: 0.75rem;
  }
  
  /* 优化表单元素在移动端的显示 */
  input, 
  select, 
  textarea {
    font-size: 16px !important; /* 防止 iOS 自动缩放 */
  }
  
  /* Element Plus 组件移动端优化 */
  .el-form-item {
    margin-bottom: 1rem;
  }
  
  .el-button {
    padding: 0.5rem 1rem;
  }
  
  /* 表格横向滚动 */
  .el-table {
    width: 100%;
    overflow-x: auto;
    white-space: nowrap;
  }
  
  /* 优化滚动体验 */
  body {
    -webkit-overflow-scrolling: touch;
  }
  
  /* 优化 Element Plus 组件在移动端的显示 */
  .el-message {
    width: 90%;
    min-width: auto;
  }
  
  .el-notification {
    width: 90%;
  }
  
  /* 表格适配 */
  .el-table__body {
    width: 100% !important;
  }
  
  /* 下拉菜单适配 */
  .el-select-dropdown {
    width: auto !important;
    min-width: 90% !important;
  }
  
  /* 优化按钮组 */
  .el-button-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  
  /* 优化表单布局 */
  .el-form-item__label {
    float: none;
    display: block;
    text-align: left;
    padding: 0 0 8px;
  }
  
  .el-form-item__content {
    margin-left: 0 !important;
  }
  
  /* 优化移动端字体大小 */
  h1 { font-size: 1.5rem; }
  h2 { font-size: 1.3rem; }
  h3 { font-size: 1.1rem; }
  p { font-size: 0.95rem; }
  
  /* 优化移动端内容间距 */
  .el-main {
    padding: 0.75rem !important;
  }
  
  /* 优化移动端表单组件间距 */
  .el-form--inline .el-form-item {
    margin-right: 0;
    width: 100%;
  }
  
  /* 优化移动端表格显示 */
  .el-table {
    font-size: 0.9rem;
  }
  
  .el-table .cell {
    padding: 8px;
  }
  
  /* 优化页面整体布局 */
  .page-container {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }
  
  /* 内容区域自适应 */
  .content-area {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: calc(var(--mobile-footer-height) + env(safe-area-inset-bottom));
  }
  
  /* 优化卡片布局 */
  .el-card {
    margin: 0.5rem 0;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05) !important;
  }
  
  /* 优化表单布局 */
  .el-form {
    padding: 0 0.5rem;
  }
  
  .el-form-item {
    margin-bottom: 1.2rem !important;
  }
  
  /* 优化按钮布局 */
  .button-group {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 0.5rem;
    padding: 0.5rem;
  }
  
  /* 优化列表布局 */
  .list-view {
    margin: 0 -1rem;
    padding: 0.5rem 1rem;
  }
  
  /* 优化弹窗布局 */
  .el-dialog {
    margin: 0.5rem !important;
    border-radius: 16px;
    overflow: hidden;
  }
  
  /* 优化表格在移动端的显示 */
  .el-table {
    width: 100% !important;
    font-size: 0.9rem;
    
    /* 确保表格内容可以横向滚动 */
    overflow-x: auto;
    display: block;
    
    /* 优化表格性能 */
    will-change: transform;
    -webkit-overflow-scrolling: touch;
  }
  
  /* 确保表格单元格内容正确显示 */
  .el-table__body,
  .el-table__header {
    width: 100% !important;
    table-layout: fixed;
  }
  
  /* 调整单元格内容显示 */
  .el-table .cell {
    padding: 8px;
    white-space: normal;
    word-break: break-word;
    line-height: 1.4;
  }
  
  /* 确保表格行正确显示 */
  .el-table__row {
    width: 100%;
  }
  
  /* 优化表格加载状态 */
  .el-table__empty-block {
    min-height: 100px;
  }
  
  /* 确保表格内容不会被截断 */
  .el-table__body-wrapper {
    overflow-x: auto !important;
  }
  
  /* 移动端下减少动态背景效果 */
  body::before {
    /* 移除或简化流光动画 */
    background: linear-gradient(135deg, #e0f2e9 0%, #d4e7f1 100%);
    animation: none;  /* 移除动画 */
  }
  
  /* 优化抽屉样式 */
  .el-drawer {
    background: #fff !important; /* 纯白背景 */
  }
  
  .el-drawer__header {
    /* 简化抽屉头部样式 */
    margin-bottom: 0;
    padding: 1rem;
    background: #fff;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }
  
  .el-drawer__body {
    /* 简化抽屉内容区域样式 */
    background: #fff;
    padding: 1rem;
  }
  
  /* 减少不必要的动画效果 */
  .reduce-animation {
    animation: none !important;
    transition: none !important;
  }
}

/* 添加安全区域适配 */
.safe-area-bottom {
  padding-bottom: calc(var(--safe-area-inset-bottom) + 1rem);
}

/* 优化移动端点击区域 */
.clickable {
  min-height: 44px;
  min-width: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 添加长按禁用文本选择 */
.no-select {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

/* 优化移动端滚动容器 */
.scroll-container {
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
  height: 100%;
}

/* 添加移动端安全区域适配 */
.has-safe-area {
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

/* 添加移动端滚动优化 */
.smooth-scroll {
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

/* 添加硬件加速 */
.hardware-accelerated {
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}

/* 优化动画性能 */
@media screen and (max-width: 768px) {
  .reduce-motion {
    animation: none !important;
    transition: none !important;
  }
  
  /* 优化滚动性能 */
  .content-area {
    will-change: scroll-position;
    contain: content;
  }
  
  /* 优化渲染性能 */
  .el-table,
  .el-dialog,
  .el-drawer {
    contain: layout style paint;
  }
}

/* 优化触摸滚动 */
@media screen and (max-width: 768px) {
  * {
    /* 优化 iOS 滚动 */
    -webkit-overflow-scrolling: touch;
    /* 防止元素闪烁 */
    -webkit-tap-highlight-color: transparent;
    /* 优化字体渲染 */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  
  /* 优化滚动容器 */
  .scroll-view {
    overflow-y: auto;
    /* 启用平滑滚动 */
    scroll-behavior: smooth;
    /* 优化滚动性能 */
    will-change: scroll-position;
    /* 提示浏览器该元素会滚动 */
    contain: strict;
  }
  
  /* 优化大列表性能 */
  .virtual-list-container {
    contain: layout size;
    will-change: transform;
  }
}

/* 暗黑模式适配 */
@media (prefers-color-scheme: dark) {
  :root {
    --mobile-bg-color: #121212;
    --mobile-card-bg: #1e1e1e;
    --mobile-text-color: #e0e0e0;
    --mobile-border-color: rgba(255, 255, 255, 0.1);
  }
}
